草庐IT

MySQL IF THEN 在 WHERE 子句中

全部标签

c# - 具有 OR 子句和空值的 lambda 表达式的 LINQ where 子句返回不完整的结果

问题简而言之我们在Where子句中使用了一个lambda表达式,它没有返回“预期”结果。快速总结在analysisObjectRepository对象中,有一些对象在名为Parent的属性中也包含父关系。我们正在查询此analysisObjectRepository以返回一些对象。细节下面的代码应该做的是,返回包含ID值的特定对象的根、第一个子对象(直接子对象)和孙对象。在下面的代码中,常识告诉我们,所有使3个单独的OR条件中的任何一个为真的结果都应该在结果中返回。ListanalysisObjects=analysisObjectRepository.FindAll().Where(

c# - 具有多个where参数的linq to sql查询

我目前正在使用EntityFramework在ASP.NETMVC4中编写搜索功能。然而,我遇到了一个障碍,我只能找到“坏”的解决方案。我的搜索函数返回一个包含4个参数的模型:StringNameStringStreetStringCodeStringProvinceListquery=(fromtinModelselectt).ToList();现在我想过滤我的搜索输入。但是,用户可以决定填写尽可能多的搜索字段。他可以决定使用姓名和街道,或姓名、街道和省份,或...我能找到的唯一真正的解决方案是使我的查询和IQueryable检查一个字段是否已经用if填充,然后使用.Where更新查

c# - 如何在 LINQ 中实现动态 'where' 子句?

我想要一个动态的where条件。在下面的例子中:varopportunites=fromoppinoppDC.OpportunitiesjoinorginoppDC.Organizationsonopp.OrganizationIDequalsorg.OrgnizationIDwhereopp.Title.StartsWith(title)selectnew{opp.OpportunityID,opp.Title,opp.PostedBy,opp.Address1,opp.CreatedDate,org.OrganizationName};有时我有Title有时我没有。我还想在wher

c# - if 子句中的可选空合并

这个问题在这里已经有了答案:Nullpropagationoperator,outparametersandfalsecompilererrors?(3个答案)关闭3年前。我的一位同事刚刚遇到了一个有趣的问题。我用下面的简单示例代码重现了这个问题。问题是编译器提示i在第三行使用时可能没有被赋值。我知道GetProperty不会被执行,如果o是null,那么i就不会执行被初始化,但在那种情况下我也不会评估inti2=i;。是否有关于可选值或空合并运算符的东西我不知道这与这里相关,或者这只是编译器不够智能的情况,无法知道i如果它不被使用没有初始化?voidTest(objecto){if(

c# - 在 Select 和 Where 调用中重用 Linq to Entities 的 Expression<Func<T, TResult>

假设我有一个实体对象定义为publicpartialclassArticle{publicId{get;set;}publicText{get;set;}publicUserId{get;set;}}根据文章的某些属性,我需要确定给定用户是否可以删除该文章。所以我添加了一个静态方法来进行检查。像这样的东西:publicpartialclassArticle{publicstaticExpression>CanBeDeletedBy(intuserId){//Addlogictobereusedherereturna=>a.UserId==userId;}}现在我可以做using(MyE

C# Linq : Combine multiple . Where() with an *OR* 子句

我一直在搜索有关我当前问题的大量信息,但找不到解决该问题的真正答案。我正在尝试构建一个生成以下SQL的LINQ查询:SELECT*FROMTABLEWHERE(Field1=X,Field2=Y...)or(Field3=Z)在正常情况下我会这样做:Object.Where(c=>(c.Field1==X&&c.Field2==Y)||(c.Field3==Z))我不能使用这种方法,因为查询是通过使用多个.Where()调用构建的。举个例子://Thisisashortexample,therealworldsituationhas20fieldstocheckandtheyareal

c# - 以动态/编程方式将 WHERE 子句添加到 SQL

如何以编程方式将搜索条件添加到SQL存储过程?在我的应用程序(C#)中,我使用存储过程(SQLServer2008R2)ALTERPROCEDURE[dbo].[PROC001]@userIDvarchar(20),@passwordvarchar(20)ASSELECT*FROMtUsersWHERERTRIM(Name)=@userIDANDRTRIM(Password)=@password我想通过更多条件扩展此查询,现在我不知道有多少条件会因程序执行而使用此查询。2、3、6或20。我想以编程方式添加这些条件,例如:SELECT*FROMtUsersWHERERTRIM(Name)

c# - 使用 .NET 中的类型化数据集将 SQL 参数传递给 IN() 子句

首先道歉,因为这个网站上有类似的问题,但没有人直接回答这个问题。我在VS2010中使用类型化数据集。我在数据集中创建一个TableAdapter,查询如下:SELECT*fromTableWHEREIDIN(@IDs)现在如果我调用:TableAdapter.Fill(MyDataTable,"1,2,3")会发生错误,指出VS无法将1,2,3转换为int类型。很公平。然后我决定将参数(即@IDs)类型更改为参数集合中的字符串。再试一次-仍然是相同的错误消息。那么这个类型化的数据集有什么方法可以接受我的“1,2,3”参数吗?目前我只有几个参数要传递,所以我可以轻松地创建5个左右的参数并

c# - Dapper 的嵌套 `using` 子句 - 澄清?

我正在了解Dapper如何在幕后工作。但是我看到了这种我不理解的处理模式。大致一般—thisQueryAsync是如何实现的:/*1*/publicasyncTask>QueryAsync(stringsql,Funcprojector,DbConnection_conn,dynamicparam=null)/*2*/{/*3*//*4*/DbDataReaderreader=null;/*5*/boolwasClosed=_conn.State==ConnectionState.Closed;/*6*/try/*7*/{/*8*//*9*/using(varcmd=_conn.Cre

c# - 给定 "where T : new()", "new T()"是否在内部使用 Activator.CreateInstance?

如果我有一个类型参数约束new():voidFoo()whereT:new(){vart=newT();}newT()是否会在内部使用Activator.CreateInstance方法(即反射)? 最佳答案 是的,这是真的。编辑2:这里很好地解释了方法和原因。http://www.simple-talk.com/community/blogs/simonc/archive/2010/11/17/95700.aspx为了验证我编译了如下方法:publicstaticTCreate()whereT:new(){returnnewT()